// Problem: 
// Contest: 
// URL: 
// Memory Limit: 
// Time Limit: 
// #pragma GCC optimize("Ofast")
// #pragma GCC optimize("unroll-loops")
// #pragma GCC target("sse,sse2,sse3,ssse3,sse4,popcnt,abm,mmx,avx,avx2,tune=native")
#include<bits/stdc++.h>
using namespace std;
#define int long long
inline int read(){
	int s=0,w=1;
	char ch=getchar();
	while(ch<'0'||ch>'9'){if(ch=='-')w=-1;ch=getchar();}
	while(ch>='0'&&ch<='9') s=s*10+ch-'0',ch=getchar();
	return s*w;
}
int N=100000001;
vector<bool> v(N);
vector<int> w;
void build()
{
	for(int i=2;i<=N;i++)
	{
		if(v[i]==0)
		{
			w.push_back(i);
			for(int j=2;j*i<N;j++)
			{
				v[i*j]=1;
			}
		}
	}
}

signed main()
{
	int T=1;
//	cin>>T;
	build();
	while(T--)
	{
		int n,q;
		cin>>n>>q;
		for(int i=1;i<=q;i++)
		{
			int x;
			cin>>x;
			cout<<w[x-1]<<endl;
		}
	}
	return 0;
}
